package com.bubaiwantong.algorithms2.insert;

/**
 * 简单插入排序
 */
public class SimpleInsertSort {

    public static void main(String[] args) {
        SimpleInsertSort simpleInsertSort = new SimpleInsertSort();
//        int[] arr = new int[]{9, 8, 7, 6, 5, 4, 3, 2, 1, 0};
        int[] arr = new int[]{9, 8, 7, 6, 0, 5, 4, 3, 2, 1};
        simpleInsertSort.printArr(arr);
        simpleInsertSort.sort(arr);
        simpleInsertSort.printArr(arr);
    }

    /**
     * 简单插入排序
     * 选择一个合适的位置插入
     *
     * @param arr
     */
    public void sort(int[] arr) {
        for (int i = 1; i < arr.length; i++) {
            int temp = arr[i];
            int j = i;
            while (j > 0 && arr[j - 1] > temp) {
                arr[j] = arr[j - 1];
                j--;
            }
            arr[j] = temp;
        }
    }

    public void printArr(int[] arr) {
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
        System.out.println();
    }

    public void swap(int[] arr, int i, int j) {
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }

}
